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1 . INTRODUCTION 



The Adaptec ACB-3530A Streaming Tape Controller Board interfaces 
a 1/4" streaming tape drive using the QIC-36 interface to any 
host interface compatible with the ANSI X3.331 - 1986 Small 
Computer System Interface (SCSI). 

1.1 ACB~3 5 30A FEATURE SET 

« Full SCSI specification, ANSI X3.331 - 1986 compatibility. 
Connects to any SCSI standard host adapter. 

« SCSI bus arbitration and disconnect/reconnect support. 
Overlapped disk/tape operation capability with multitasking 
l/O subsystems. 

• Buffered write and immediate command completion support. 
Data buffering and immediate completion mode for streaming on 
systems that do not support SCSI bus disconnect/reconnect. 

# QIC-24 and QIC-11 media format support. 

Capable of reading and writing QIG-24 and QIC-11 format tapes. 

m 16-Bit CRC on each record and SCSI bus parity. 

Data integrity is assured by reading the data and checking CRC 
immediately after it is written. CRC is also checked on tape 
reads. In addition, SCSI bus parity is checked or generated 
on all bus transfers. 

m Automatic tape defect handling. 

Media defects detected by the controller from read after write 
will result in the data being rewritten in the next sequential 
block. 

» Reserve/Release. 

The tape drive can be reserved by an attached host to restrict 
other host accesses to the data. 

1.2 REFERENCE DOCUMENTS 

» ANSI X3.331 - 1986 Small Computer System Interface Specifica- 
tion. 

♦» QIC-24 Specification: Proposed standard for data interchange 
on streaming 1/4" drives. 
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o QIC-11 Specification: Proposed standard for data interchanqe 
on streaming 1/4" drives. 

o QIC-36 Specification: 1/4" streaminq tape drive basic inter- 
face. . 

1 .3 ACR~3 530A CONTROLLER BOARD LAYOUT 

The dimensions and component layout of the ACB-3530A is shown in 
Figure 1-1. This diagram is referred to later in the manual for 
the location of the interface connectors, bus terminators, and 
configuration jumpers. 
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FIGURE 1-1. ACB-3530A BOARD LAYOUT 
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1.4 PRODUCT SPECIFICATION 

The ACB-3530A controlleris designed to function under normal 
operating conditions for electronic components. The form factor 
issuch that the control ler can be mounted with the drive in most 
systems. 

1.4.1 PHYSICAL DIMENSIONS 

Length: 8.00 inches (18,1 cm) 
Width: 5.50 inches (14.6 cm) 
Height: 0.75 inches ( 1.9 cm) 

1.4.2 POWER REQUIREMENTS 

+5 VCD + 5% at 1.8 Amps (max) 
-f-12 VDC + 10% at 100 mAmp (max) 

1.4.3 ENVIRONMENTAL REQUIREMENTS 



OPERATING 



STORAGE 



Temperature (f/c): 
Humidity (non-cond) 
Altitude: 



32°/0° to 131°/55° 

10% to 95% 

to 10,000 MSL 



-40^/-.40° to 167°/75^ 

10% to 95% 

to 10,000 MSL 



Exhaust air flow may be required to keep the air on both sides of 
the board at or below the maximum operating temperature. 
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2.0 THEORY OF OPERATION 



The ACB-3530A architecture is designed around the Adaptec 
controller chips; the AIC-010 and AIC-300. This architecture 
divides the controller into two basic components/'a data path and 
a control path. A block diagram of the ACB-3530A is shown in 
Figure 2-1. 

2.1 ACB-3530A ARCHITECTURE 

The AGB~3530A data path carries data to and from the attached 
QIC-36 tapedrive and host. Datais transferredin an 
asynchronous fashion from the host to/from the controller 8K- 
dual-ported buffer RAM. The buffer dual-port addressing and port 
handshaking is controlled by the AIC-300. Odd bus parity is 
checked on data transferred into the buffer and generated on data 
transferred onto the SCSI bus. The dual-ported buffer is 
designed to allow data to be written into one port (i.e., from 
the host) as it is being read out from the other (i.e., to the 
tape) in a FIFO fashion. 

Data is transferred between the RAM buffer and the AIC-010 
sequencer using synchronous timing to assure streaming operation. 
Data is converted into a serial NRZ data stream in the OIC-24 
format by the AIC-010. • The QIC-24 ID and data fields are then 
appended with CRC information. This NRZ data stream is encoded 
into the GCR encoding scheme and written onto the tape. As data 
is being written, the ACB-3530 is also performing a CRC check on 
the data and will rewrite blocks if any errors are detected. 

An eight-bit microprocessor is used to initialize and monitor the 
status of the data path and serves as the main component of the 
control path. The microprocessor drives the SCSI control lines 
to sequence through the various bus phases and decodes all SCSI 
commands. The microprocessor is further used in the SCSI 
interface to report all errors encountered and to transfer 
messages to the host. 

The microprocessor also performs the main controlling functions 
on the QIC-36 interface. These include track select, motion 
control, and cartridge status (in or out). 
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FIGURE 2-1. ACB-3530A BLOCK DIAGRAM 

2.2 MICROCODE STRUCTURE 

The controlling microcode for the ACB-3530A is preprogrammed in 
16K of EPROM memory. This firmware contains all routines 
necessary to properly interface to the SCSI bus and the QIC-36 
interface and to control the tape data path. Figure 2~2 shows a 
basic flow chart for the controller firmware. 
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FIGURE 2-2. AdB~3530A CONTROLLING FIIWW^RE 
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2.3 SELF TEST 

The self test function is automatically executed on the ACB-3530A 
upon power-up or after an SCSI reset. The self test executes in 
300 ms, and during this time the controller will not respond to 
any selection requests from the SCSI bus. During the test, the 
red LED on the front of the board will be illuminated. If the 
self test is failed, the LED will blink rapidly, at a rate of 
approximately 4 Hz. 

The loop-on-self test feature is invoked on the ACB-3530A by 
holding SCSI ACK true while SCSI BSY is floating (false). During 
this condition, the self test function will loop on itself. 
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3.0 INSTALLATION OF THE ACB-3530A 



The ACB-3530A is designed to provide the perfo^rmance and 
flexibility required to reliably operate a QIC-36 1/4" tape drive 
for streaming backup of system data. Some basic installation 
steps are required to assure proper board operation. 

3.1 UNPACKING 

The AGB-3530A is shipped in a protective carton with shock- 
absorbing and static protection material completely surrounding 
the card. The carton should be examined for external damage as 
it is opened. The cards are physically inspected prior to 
packaging, any damage noted should be reported immediately. 

CAUTION: ALL CIRCUIT BOARDS CONTAINING VLSI CIRCUITRY HAVE SOME 
SENSITIVITY TO ELECTROSTATIC DISCHARGE. THE ACB-3530A IS NO 
EXCEPTION. PROPER HANDLING PRECAUTIONS, INCLUDING PERSONNEL AND 
WORK SURFACE GROUNDING, SHOULD BE TAKEN TO PREVENT CIRCUIT STRESS 
WHICH CAN CAUSE COMPONENT FAILURE. 

3.2 PREPARATION OF INSTALLATION AREA 

The ACB~3530A is generally designed into the physical host system 
or a peripheral subsystem. Proper attention should be given to 
the location of the ACB-3530A to assure that necessary 
ventilation, installation clearances, and cabling paths are 
provided. 

3.2.1 MOUNTING CONSIDEPJKTIONS 

The ACB-3530A can be physically mounted using the four mounting 
holes. These holes are in locations compatible with standard 5- 
1/4" Form Factor for mounting onto the drive. The controller can 
also be mounted onto custom designed brackets for alternate 
mechanical requirements. Care must be taken, however, to 
consider the physical forces the system will be subject to. No 
conductive material should come in contact with the ACB-3530A PC 
card. 
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3«2.2 RF CONSIDERATIONS 

The ACB-3530A and all other partially shielded electronic devices 
are sensititve to high power, high frequency or magnetic sources. 
The controller should be protected from such sources. In 
particular, unshielded switching power supplies should be 
physically isolated from all electronic boards and 
interconnecting cables. Additional cable shielding may be 
required in some environments, 

3.3 ACB-3530A CABLING 

The ACB--3530A is connected into the host system or subsystem 
using board connectors Jl, J3 and J4. The connectors are used as 
follows: 

Jl - 50 Pin QIC-36 Connector (Section 4.1) 
J3 - 50 Pin SCSI Connector (Section 5.2) 
J4- 4 Pin Power Connector (Section 3.3.1) 

Figure 3-1 shows proper system cabling. Take care to note Pin 1 
orientations of all connectors. These are easily found by 
locating the square solder pad on the solder side of the PC 
board. 

NOTE: 

IF THE ACB-3530A IS NOT THE LAST CONTROLLER ON THE SCSI BUS, THE 
SCSI TERMINATORS, RNl, RN2, AND RN3, SHOULD BE REMOVED, 




POWER 



ACB'3630A 




FIGURE 3-1. ACB-SSaOA SYSTEM CABLING 
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3.3.1 ACB-3530A POWER CONNECTOR, J4 

Figure 3-2 shows the pin assignments for power connector, J4. 
The suggested mating connector to J4 is AMP P/Nl -480424-0 or 
equiva lent. 



[^ 


+ 12V 


® 


+ 12V RETURN 


(S) 


+5V RETURN 


l@ 


+ 5V 



FIGURE 3-2. POWER CONNECTOR, J4, PIN ASSIGNMENTS 

3.4 ACD-3530A CONFIGURATION 

The ACB-3530A requires a minimum of hardware setup. 

The function of J6 through JIO is shown in Table 3-1. Sections 
3.4.1 and 3,4.2 detail these functions. 

TABLE 3-1. ACB-3530A CONFIGURATION JUMPERS. J6 





J6 


00 




J7 


00 




J8 


00 




J9 


00 




JIO 
SCSI BUS ADDRE 


00 


3.4.1 


SS 



SCSI Bus Address 2 







SCSI Bus Address 2^ 
SCSI Bus Address 2^ 
SCSI Parity Disable 
Spare 



The insta 1 lation of jumpers J6, J7 and J8 set the address ID of 
the ACB-3530A on the SCSI bus. SCSI devices can have bus 
addresses of zero to seven, however, no two devices may have the 
same address. A jumper installed indicates a logicalone bit 
address. 
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3.4.2 SCSI BUS PARITY DISABLE 

The installation of jumper J9 will disable the ACB-3530A odd bus 
parity check on all data transferred from the host. If the 
attached host does not generate parity, parity must be disabled. 
The ACB-3530A will always generate odd parity on data transferred 
to the host. 

3.4.3 SCSI BUS PARITY OPERATION 

— — — — i ■■■■■!■■■ ■!■ ■ — W II H M W III I — ■■■■II MW Il ■■■■■■ ■ ■■■■I— W— ii»»»l. I III ll—W— »■ IIMIWI I ■ 

The ACB-3530A incorporates full SCSI bus parity generation and 
verification. The handling of parity errors by the controller is 
detailed below. 

Parity error on ID Message or Command Byte 

A parity error on either an ID message to the controller or on 
the transfer of command bytes to the controller will result in 
the command terminating after transmission of all six command 
bytes with a Sense Key of 04h (Hardware Error) and Sense Byte 08, 
bit 2 set. 

Parity Error on Data to Controller During WRITE DATA 

A parity error on data out to the controller during a WRITE DATA 
command is latched and checked at the end of the trans fer of each 
block from the host. Detection of a parity error will result in 
the command being terminated with a Sense Key of 04h and bit 2, 
sense byte 09 set. The block which resulted in a parity error 
will NOT be written onto the tape. The residue count will, as 
usual, show the number of blocks remaining to be transferred to 
the tape. 

Parity Error on Message to Controller 

On any Message Out to the controller, a parity error will cause 
the command in progress to be terminated with a Sense Key of 04h 
and bit 2, sense byte 09 set. The message itself will be 
ignored. This situation is always followed by a Status Out phase 
(status = 2), then by a Message Out phase, which terminates the 
command , 



{Inxziiizor Det-ect-ea Error j. In a i '^ cc.B.aBt -r.^s -»:.'.. : 
the command in progress terminating with a Ser.i^ : 
(command aborted). For Read and Write commands, rr. 
count will be valid. 
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For Read commands, any data and/or status which resulted from 
"Lying Read" type operations (i.e., from the tape process being 
ahead of the SCSI process) will be disregarded. The tape will 
then be positioned at the end of the last record transferred to 
the host before the Initiator Detected Error message was 
received. Thus, the host will be able to retry the operation by 
backspacing the tape and rereading. 

While transferring Data Out during a Read command, the ATTN will 
be checked between blocks to allow the host to notify the 
controller of a parity error on Data In. It should be noted that 
if the host waits more than 128 blocks between the time it 
detects a parity error on Data In and the time it notifies the 
controller of this fact by raising ATTN and sending an Initiator 
Detected Error message, backspacing to recover from the error 
will not be possible (as per current QIC-36 specification. 
Reverse Space commands are limited to 128 blocks). 

3.4.4 SCSI RECONNECT 

When attempting to reconnect after having disconnected, the ACB- 
3530A will wait 250 ms for the host to assert BSY after the ACB- 
3530A has won arbitration for the bus. If the host does not 
respond before the 250 ms expires, it will clear the data bus and 
check once more for BSY, If the host still has not responded, 
the I/O operation is immediately terminated and no further 
attempts to communicate with the host will be tried without 
rearbi tra t ion. See pages 5-6 and 5-12 in this manual for more 
information on this feature. 

3.5 POWERING ON THE ACB-3530A 

The ACB-3530A, once properly cabled and configured, can be 
powered-on. Power should not be applied to the controller if 
activity is present on the attached SCSI bus. The electrical 
nature of the components typically used to drive this interface 
could interrupt bus activity. 

If a cartridge is installed in the attached drive at power-on, 
the controller will rewind it to BOT to prepare for read and 
write accesses. 

If a cartridge is installed some time after power-on, it will be 
rewound by the controller upon insertion. 

The controller will present a Busy status to any access attempts 
made during the power-on cartridge insertion tape rewind. 



400112-OOA 3-5 November, 1986 



4.0 QIC-36 1/4" STREAMING TAPE INTERFACE 



The QIC--36 interface provides a low-cost, high-performance, 
standard interface for attaching a 1/4" streaming tape drive to 
intelligent controller/formatters. This section describes the 
interface between the ACB-3530A and a QIC-36 tape drive. 

4.1 QIC-36 INTERFACE SIGNALS 

The QIC-36 interface is implemented through a 50-pin dual-in-line 
header located at position Jl on the ACB-3530A. The suggested 
mating connector is 3M P/N 3425-60XX, 3425-70XX or equivalent. 
Maximum cable length is 10 feet (3 meters). 

The connector pins are numbered 1 to 50. All odd pins are signal 
returns and are connected to the controller board ground. Table 
4-1 shows Jl pin assignments. 
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QIC-36, Jl, CONNECTOR PIN ASSIGNMENTS 



SOURCE 

C 
C 
C 
C 

c 
c 
c 
c 
c 
c 
c 
c 

D 
D 
D 
D 
D 
D 
D 
C 
C 
C 

c 
c 
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DESCRIPTION 



Tape Motion Enable 



Tape Direction Control 

Select 2^ 

Select 2^ 

Select 2?^ 

Select 2" 



Track 
Track 
Track 
Track 
Reset 



(Initialize Drive) 
Reserved (not used) 
Reserved (not used) 
Reserved (not used) 
Drive Select 
High V/rite Current 
Read Data (Pulse Output) 
Upper Tape Position Code 
Lower Tape Position Code 
Drive Select Response 
Cartridge In Place 
Unsafe (No Write Protect) 
Capstan Tachometer Pulse 
Write Data Signal - 
Write Data Signal + 
Threshold (35% Read Mrgn ) 
High-Speed Slew Select 
Write Enable 
Erase Enable 
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A detail of the QIC-36 interface signals follows: 

Go (GO-): Assertion of GO- causes a start tape motion sequence in 
the direction specified by the state of REV-. 

Reverse (REV-): Assertion of REV- will cause tape motion in the 
reverse direction i f GO- is asserted. Deassertion of REV- will 
cause tape motion in the forward direction. 

Track Select (TRO-, TR1-, TR2-, TR3-)s Assertion of the track 
select signals will result in the selection of track through 3, 
on a four-track drive, or through 8, on a nine-track drive. 
Track selection is made through binary assertion of these lines 
with TRO- the least significant. 

Reset (RST— ): Assertion RST- will cause the tape drive to 
reinitialize. This sequence differs between drive vendors. 

Drive Select (DSO-)/Drive Selected (SLD-): The assertion of DSO- 
selects the attached tape drive to allow all tape operations to 
proceed. The drive selected signal (SLD-) will be asserted by the 
drive in response to selection. 

High Current (HC-): Assertion of HC- enables the tape drive to 
use a higher write current when writing to the drive. 

Read Data Pulses (RDP-): Serial read data is passed to the 
controller as a pulse for every flux change. Since no read enable 
is required. Read Data Pulses will be present any time data passes 
under the tape read head and DSO- is asserted. 

Upper Tape Hole (UTH-)/Lower Tape Hole (LTH-): The UTH- and LTH- 
signals are generated by the drive to indicate some media status. 
The BOT, Load Point, Early Warning, and EOT tape holes are encoded 
to produce an output code indicating specific positions of the 
tape. 

Cartridge In (CIN-): The GIN— signal is asserted by the drive 
when a cartridge tape is fully installed and DSO- is asserted. 
The line is deasserted when the cartridge is removed. 

Unsage (USF-): The USF- signal is asserted by the drive to 
indicate that the installed cartridge is not write protected. 
This signal will be asserted when the write protect plug is in the 
unsafe position and DSO- is asserted. 

Tachometer Pulses (TCH-): The tachometer pulses generated by the 
rotation of the capstan motor inform the controller when the tape 
is in motion and how fast, DSO- must be asserted for this signal 
to be valid. 



Write Data (WDA+# WDA-): WDA lines are diff erentia Lly driven and 
contain tape write data from the controller. WEN- must be 
asserted prior to writing to the tape. 

Threshold (THD-) : Assertion of THD- Invokes a 35% qualifying 
amplitude for the read signal. This is typically used to 
eliminate marginal tape recording areas, 

High-Speed (HSD-): Assertion of HSD- causes 30 ips tape drive to 
operate at 90 ips speed. 

Write Enable (WEN-); Assertion of WEN- allows write data to be 
written to the tape. 

Erase Enable (EEN-): Assertion of EEN- enables erase current to 
the full tape width erase head. DSO- and TRO- must also be 
asserted. 

4.2 BLOCK FORMAT 

The ACB-3530A is designed to read and write user data, control 
information and file marks in the QIC-24 and QIC-11 media 
formats. Both media format standards are supported with a 512- 
byte block size and are shown in Figure 4-1. 
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13,0 (MIN.) 


0.5 
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4 


2 



GAP 



SYNC 



DATA 
QIC-24 BLOCK FORMAT 



BLOCK CRC 

NUMBEP 



FIGURE 4-1. QIC-11 AND QIC-24 BLOCK F0R^mT 

4.2.1 FILE MARKS 

Data blocks can be used to create "marks" on the tape, typically 
between recorded files. File marks are written to the tape when 
specified by the host using a unique data pattern in the 512-byte 
data field. The host can then use file marks as boundaries for 
spacing and streaming reads. 
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4.3 TRACK LAYOUT 

Data is read and written in a serpentine fashion betwen the tape 
early warning holes. Load Point and Early Warning. When the 
controller encounters the end of a track, the tape reverses 
direction- and continues the read or write. Even-numbered tracks 
are recorded while the tape is moving forward. Odd-numbered 
tracks are recorded while the tape is moving backward. The 
controller reports an overflow state when the end of the last 
track is encountered (Early Warning). While writing on trackO, 
the tape erase head will be activated ahead of the write data. 
Figure 4-2 shows the layout of an entire 1/4" tape and the 
relative location of the tape positioning holes. 
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FIGURE 4-2. 1/4'* TAPE LAYOUT 

4.4 TAPE MEDIA DEFECT HANDLING 

The ACB-3530A checks each block on the tape for good CRC as it is 
being written. However, since the tape read head trails the 
write head by about 300 bytes, the CRC results for a given block 
(block N) are not known until the next block write has begun. 
The controller, therefore, assumes that the previous block will 
check correctly and begins writing the next block as such. 

If the CRC check should fail, typically due to a media defect, the 
ACB-3530A will complete the current block write (N+1) and then 
rewrite the previous block (N). This alternation between N is 
achieved or 16 unsuccessful writes have been attempted. If block 
N were the last block to be written, it would be repeated until a 
good CRC check is made. This results in the last block of each 
write to be Written at least twice. 

This process is effective in that the ACB-3530A will not attempt 
to read N+1 until a valid read from block N is made. 
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5.0 SCSI INTERFACE DESCRIPTION 



This section briefly describes the SCSI protocol implementecl by 
the ACB-3530A. The SCSI protocols are further defined in the 
ANSI X3.331 - 1986 specification. 

5.1 GENERAL DESCRIPTION OF SCSI 

The SCSI is a device-independent method of interfacing up to 
eight host computers and peripheral devices. Device independence 
relates to the ability to communicate with a number of peripheral 
types without regard to the physical characteristics of the 
device (i.e., number of tracks, tape capacity, etc.). 

The SCSI interface, based on the IBM block multiplexer l/o 
channel, provides optimum performance in host-to-host and host- 
to-peripheral communication. The SCSI is implemented through a 
50-pin ribbon cable that is daisy chained to all attached hosts 
and peripheral controllers. The SCSI can support up to eight 
devices. A single device, such as a disk controller, can support 
a number of peripherals. The daisy chained SCSI cable must be 
terminated at both ends. Figure 5-1 shows the ACB-3530A in a 
typical SCSI configuration. 



Communication occurs across the bus in a Request/Acknowledge, 
asynchronous fashion. The asynchronous bandwidth of the SCSI bus 
is 1.5 Mbyte/sec maximum. When two devices communicate across 
the bus, the device initiating the command assumes an INITIATOR 
role, the other device required to execute the command is 
designated as the TARGET. Host computers are almost always 
INITIATOR'S, controllers are transferred and executed across the 
bus using a number of bus "phases," The phases determine what 
type of information (command, data, status, etc.) is being 
transferred at any given time. 

In order to execute a command, the INITIATOR (host) must first 
gain control of the SCSI bus, this is accomplished through 
arbitration. The host then selects the required controller. 
From this point on, the controller determines all bus phases and 
byte transfers* The host interface must make no assumption 
regarding the sequence of bus phases, as error conditions can 
cause the controller to change the bus state in the middle of 
command and data transfers. 
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FIGURE 5-1. TYPICAL SCSI COWFIGURATION 

5.2 SCSI BUS SIGNALS 

The SCSI bus contains nine control signals, controlling the bus 
phase and all byte transfers, and nine data signals. The 
interface is implemented using a 50-pin dual-in-line header at 
location J3. All odd numbered pins are ground. The suggested 
mating connector is 3M P/N 3425-60XX, 3425-70XX or equivalent. 
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TABLE 5-1. SCSI CONNECTOR, J3, PIN ASSIGNMENTS 
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Data Bit 6 
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Bus Terminator Power 
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Attention 
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Acknowledoe 
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Reset 
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MSG- 


Message 
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SEL- 


Select 
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C/D- 


Control/Data 




47 


o o 
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REQ- 


Request 


Ret 


:urn 49 


o o 


50 


I/O- 


Input /Output 



A description of each signal is as follows: 

Busy (BSY-): BSY- is an "or-tied" signal that indicates that the 
bus is in use. The ACB-3530A will assert busy upon being 
selected by an SCSI host. 

Select (SEL-): SEL- is an "or-tied signal that is used to select 
an SCSI device. The SEL- line can be used by a host to select a 
controller to initiate a command or by a controller to reselect a 
host to complete a command (see Section 5.3). 

Input/Output (I/O-) 5 l/O is driven by the controller to indicate 
the direction of information transfers on the SCSI bus relative 
to the host. Assertion of this signal. In, indicates a 
controller-to-host transfer. Out indicates a host-to-controller 

transfer. 
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Control/Data (C/D~): C/D- is driven by the controller to 
indicate whether a control or data byte is being transferred 
across the bus. The type of control information is indicated by 
the I/O line. Inbound, controller to INITIATOR, control 
information is status. Outbound control information is commands. 
I/O also indicates the direction of data transfers. 

Message (MSG-): MSG is given by the controller to indicate a 
request to send or receive an SCSI message. This signal will be 
asserted when the controller desires to send a message, or, in 
response to t he host asserting ATN-, indicating a host request 
to send a message. 

Attention (ATN-)s ATN- is driven by the host to indicate a 
request to transfer a message to the selected controller. 

Request (REQ-): REQ- is driven by the controller to initiate the 
REQ/ACK asynchronous handshake of a byte of information to or 
from the host. The type of information is indicated by the C/D-, 
l/O-, and MSG- signals. 

Acknowledge (ACK-): ACK- is driven by the host to complete the 
REQ/ACK asynchronous handshake of a byte of information to or 
from the host. 

Data Bits and Parity (DBO- to DB7-, DBP-): The SCSI contains an 
eight-bit parallel bus, plus odd parity, DBO- is the least 
significant. 

5,3 SCSI BUS PHASES 

The SCSI bus has eight distinct operational phases that are 
controlled by the ACB-3530A by the assertion of one or more of: 
C/D, I/O, MSG, SEL, and BSY, The eight phases are: 

m Bus Free « Command* 

m Arbitration » Data* 

m Selection « Status* 

« Reselection m Message* 

*Information transfer phases. 

In execution of §CSI operations, the bus will sequence through a 
number of these phases. When the bus is between phases, the BSY, 
SEL, REQ, and ACK signals may not change. The C/D, I/O, MSG and 
data lines may change. 
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The following sections describe the sequence of events contained 
within each bus phase, refer to Figure 5-2 and Section 5.5 for 
relative bus timing. 

5.3.1 PUS FREE PHASE 

The Bus Free phase, indicating that the bus is free and available 
for use is entered by the deassertion and passive release of all 
bus signals. At the completion of an SCSI operation, the active 
device(s) must deassert all bus signals within 800 ns of release 
BSY. 

SCSI devices sense the Bus Free phase when SEL and BSY are 
deasserted and the Reset condition is not active. 

5.3.2 ARBITRATION PHASE 

The Arbitration phase allows one SCSI device to gain control of 
the bus in systems where more than one device may require the use 
of the bus. Systems with one host and SCSI devices that do not 
support reconnection may skip this phase, by entering the 
Selection phase directly from Bus Free. 

The sequence of arbitrating for the bus is as follows: 

1. Wait for Bus Free phase: deasserting of both SEL and BSY. 

2. After Bus Free is detected, the arbitration device waits a 
minimum of 800 ns (bus free delay) to assert BSY and the data 
bit corresponding to the device's SCSI address ID. 

3. The arbitration device then looks on the data bus for an ID 
of higher priority. If no higher priority ID's are present, 
the device has won control of the bus. If higher priority 
id's exist the device returns to Step 1. 

4. After winning arbitration, the device asserts SEL and enters 
the Selection or Reselection phase, 

5.3.3 SELECTION PHASE 

The Selection phase allows an INITIATOR (host) with control of 
the bus to select a TARGET (controller) to initiate an SCSI 
command. 
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The sequence for a host to select a controller is as follows: 

1. To select a device in nonarbitrating systems, the host 
asserts the controller ID address bit and optionally asserts 
it ' s own ID. 

When selecting a device from the Arbitration phase, the host 
already has SEL asserted (along with BSY) . The host asserts 
the controller ID and its own ID and then deasserts BSY. 

2. On detecting the simultaneous condition of SEL and its own ID 
asserted, and l/o and BSY not asserted, the selected 
controller examines the data bus for the host ID and responds 
by asserting BSY. 

3. The host then deasserts SEL and ID address data bits. 

5.3.4 RESELECTION PHASE 

The Reselection phase is used to re-establish a connection 
between a host and controller in order to continue a disconnected 
operation. This phase is entered from the Arbitration phase. 
Like the Selection phase, the SCSI device with control of the bus 
has both SEL and BSY asserted. The Reselection phase differs 
from the Selection phase by the assertion of l/O. 

The sequence for a controller to reselect a host is as follows: 

1. The controller asserts l/O and the data bits corresponding to 
its own ID address and the desired host ID address. The 
controller then deasserts BSY. 

2 . On detecting the simultaneous condition of SEL, l/O and its 
own ID asserted and BSY not asserted, the reselected host 
examines the data bus for the controller ID and responds by 
asserting BSY. 

3. After detecting the assertion of BSY, the controller also 
drives BSY and then releases SEL and the ID address bits. 

4. The host then deasserts BSY leaving the bus in the same state 
as at the completion of the Selection phase. 

5.3.5 INFORMATION TRANSFER PHASE 

The Command, Data, Status, and Message phases are used to 
transfer data or control information across the data bus. 

The C/D, I/O, and MSG signals are used to differentiate the 
various information transfer phases. These signals are not 
considered valid unless REQ is asserted. Table 5-1 shows the bus 
phases related to the C/D, l/O, and MSG signals. 
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TABLE 5-2. INFORMATION TRANSFER PHASES 





SIGNAL 






MSG 


C/D 


I/O 


PHASE 







1 
1 
1 
1 




1 
1 



1 
1 




1 



1 



1 



1 


Data Out Phase 
Data In Phase 
Comma nd Pha s e 
Status Phase 

- Not Used 

- Not Used 
Message Out Phase 
Message In Phase 


NOTE: 

"1" INDICATES 
TRUE). 


SIGNAL 


ASSERTION (SCSI BUS i 



DIRECTION OF 
INFORMATION XFER 

Host to ACB-3 5 30A 
ACB-3530A to Host 
Hoat to ACB-3 530A 
ACB-3530A to Host 



Host to ACB-3530A 
ACR-3530A to Host 



SIGNALS ARE NEGATIVE 



The information Transfer Phases use the REQ/ACK handshake to 
control data transfers. Each REQ/ACK allows the transfer of one 
byte of data. The handshake starts with the controller asserting 
the REQ signal, requesting a byte transfer. The host responds by 
reading or writing a byte of data from/to the bus and asserts 
ACK. The controller then deasserts REO, causing the host to 
deassert ACK. See Figure 5-2. 

A controller to host data transfer (I/O asserted) occurs with 
the ACB-3530A placing data on the bus, assuring it is valid at 
the host interface, and asserting REQ. The host then reads the 
data and asserts ACK. 

A host to controller transfer (l/o deasserted) occurs with the 
controller asserting REQ, requesting a byte of data from the 
host. The host places data on the bus, assuring it is valid at 
the controller interface, and asserts ACK. 



The BSY signal remains asserted 
Transfer Phases. 



throughout the Information 
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FIGURE 5-2. REQ/ ACK HANDSHAKE 



5.3.5.1 COMMAND PHASE 

The Command phase is used by the ACB-3530A to obtain Command 
Descriptor Blocks (CDB) from the host. The sequence for a 
command transfer is as follows: 

1. A host, in order to execute a command, arbitrates for the bus 
(if arbitrating system) and selects the ACB-3530A, 

2. The ACB-3530A becomes selected and places the bus in a 

Command phase with REQ asserted. 

3. The command is passed, in a 6-byte block, to the ACB-3530A 
using the REQ/ACK handshake and begins execution. 

Section 5.6 details the content of a SCSI Command Descriptor 
Block. 
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5.3.5.2 DATA PHASE 

The Data phase includes both Data In and Data Out. The Data In 
phase is used by the ACB-3530A to transfer tape data or control 
information (i.e., error codes or configuration data) to the 
host. The Data Out phase is used by the host to transfer tape 
write data or control information to the ACB-3530A. 

The Data phase is typically entered after the Co^imand phase and 
like command transfers, data is transferred using a REQ/ACK 
handshaking. 

5.3.5.3 STATUS PHASE 

The Status phase is used by the ACB-3530A to inform thehost of 
the state in which the last command completed. The controller 
can enter the Status phase at any time to indicate a detected 
error. If an error is detected during the six-byte command 
transfer, the ACB-3530A will transfer all six bytes and then 
enter the Status phase. The • controller will immediately invoke 
the Status phase if an error is encountered during a data 
transfer. Status information is transferred in single byte from 
the controller to host. Section 5.7 details the SCSI status 
information. 

5.3.5.4 MESSAGE PHASE 

The Message phase includes both Message In and Message Out. The 
Message In phase is used by the AGB-3530A to transfer acontrol 
message to the host (i.e., prepare to disconnect). The Message 
Out phase is used by the hot to transfer a control messge to the 
controller (i.e., abort operation). In order to enter the 
Message Out phase the host must assert the ATN line which causes 
the controller to accept the message. Section 5.8 details the 
messages supported by the ACB-3530A. 

5.3.6 SCSI BUS PHASE SEQUENCING 

The execution of commands typically consists of a number of SCSI 
bus phases. Figure 5-3 shows a typical seguence of bus phases. 
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FIGURE 5-3. SCSI BUS PHASE SEQUENCING 
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5.4 BUS CONDITIONS 

The SCSI bus has two conditions that can interrupt normal phase 
sequencinq and initiate certain device activity. These are the 
Attention and Reset Conditions. 

5.4.1 ATTENTION CONDITION 

The Attention condition allows the host to signal the ACB-3530A 
of a waiting message. The ACB-3530A accesses the message by 
invoking a Message Out phase and handshaking the message from the 
host. 

The host may create the Attention condition by asserting ATN at 
any time except the Arbitration and Bus Free phase. When the 
message byte is to be transferred the host deasserts the ATN 
signal once the Message Out phase is entered. 

The ACB~3530A may not be able to respond to the Attention 
condition immediately so the host must continue to support the 
other bus phases while ATN is asserted. 

5.4.2 RESET CONDITION AND ABORT MESSAGES 

The Reset condition is used by the host to clear all devices from 
the SCSI bus. This condition is created by asserting the RST 

signal. 

Reset can ccccr at any tirr.e an-S takes precedence over all other 
bus phases and conditions. On reset, all devices immediately 
deassert and passively release all bus signals, thus entering a 
Bus Free phase. 

The RST signal must stay asserted for at least 25 uS, while 
asserted, no other bus signals can be assumed valid. 

The ACB-3530A supports the SCSI "hard" reset mode. Upon reset, 
the ACB-3530A releases all bus signals and immediately clears any 
commands in process. The ACB-3530A will also rewind the tape to 
EOT. 

The next command to the ACB-3530A after reset will result in a 
Check status. The Request Sense (15h) command will return a 
sense key Unit Attention (6). 

The ACB-3530A will respond identically to Abort Messages and SCSI 
Reset Messages. The response will be a f u 1 1 reset of the 
controller, exactly as an SCSI hardware reset. 

5.5 SCSI BUS TIMING 

SCSI bus timing is shown in Figure 5-^4, The SCSI specification 
can provide further timing detail if required. 
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FIGURE 5-4, SCSI BUS TIMING (CON'T) 
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FIGURE 5-4. SCSI BUS TIMING (CON'T) 
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5.6 COMMAND DESCRIPTOR BLOCK 

Commands transferred from a SCSI host to the ACB-3530A are in the 
form of a six-byte block. The command block, Command Descriptor 
Block (CDB), is a predefined format shown in Figure 5-5, The CDB 
contains a command opcode, the peripheral device being addressed 
and the number of blocks to be accessed within that peripheral. 

The ACB-3530A supports the SCSI class 0, six-byte, command 
blocks. 



BIT 
BYTE 

00 

01 

02 

03 

04 

05 



FIGURE 5-5. CLASS CDB SUPPORTED BY THE ACB-3530A 

A description of each CDB field is as follows: 

Class Code: The class code defined by the SCSI specification are 
through 7, The ACR-3530A supports only class 0, six-byte 
commands. This field must therefore always be zero. 

Command Opcode: The command opcode indicates the command to be 
executed to the controller. The opcodes defined by the SCSI 
specification are OOh through Ifh. The commands suported by the 
ACB-3530A are detailed in Section 6.0. 

Logical Unit Number: The logical unit number refers to the 
peripheral devices attached to the SCSI controller. SCSI allows 
for up to eight peripherals ( logica 1 units ) , however, since the 
ACB-3530 only supports one QIC-36 tape drive, this field must 
always be logical unit number 0. 

Block Count: The number of blocks field indicates the total 
number of consecutive blocks accessed. A data transfer will 
begin at the position of the tape and continue for the total 
number of blocks indicated. 
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Control Byte: The control byte is used to indica te SCSI- 1 inked 
commands and is used by some vendors for vendor-unique features. 
Most ACB-3 5 30A commands do not support any control byte 
extensions. 

The definition of each field within the CDB can vary for each 
SCSI command. Refer to Section 6 for the CDB for each command 
supported. 

5.7 COMPLETION STATUS BYTE 

A byte of status information is transferred from the controller 
to the host during the SCSI Status phase. The Status phase is 
invoked at the completion of every command. If an error state is 
encountered during data transfers or command execution, the ACB- 
3530A will also invoke the Status phase. Errors encountered 
during a "buffered" write operation will be reported with the 
next command. 

Figure 5-6 shows the Completion Status byte. 
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FIGURE 5-6. COMPLETION STATUS BYTE 

A OOh status byte at the completion of a command indicates good 
status, or proper command completion. The ACB-3530A supports 
three additional status states: Busy, Check, and Reservation 
Conflict. Bits 0, 2, 5, 6, and 7 will always be set to zero. 
Bits 1, 3, and 4 are described as follov/s: 

Busy (Bit 3): The controller is unable to accept the command 
because of the power-on self test in process or a previous 
command still in process, typically an immediate load/unload or 
rewind. This status will occur immediately after a six-byte 
command is transferred. 

Check (Bit 1): An error condition pr even ted s ucce s s fu 1 
completion of the active command. The nature of the error can be 
obtained through the Request Sense command (03h). This status 
can occur at any time during the transfer and execution of a 
command. 

Reservation Conflict (Bit 4): A reservation conflict exists. 
When this bit is set with bit 3, Busy, the command issued is in 
conflict with an existing tape drive reservation. This status 
can be returned as a result of a tape access or d reservation 
request. 
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5.8 SCSI MESSAGE SYSTEM 

The message system allows communication between an Initiator and 
an ACB-3530A for the purposes of physical path management. This 
section describes the messages supported by the ACB-3530A. 

5.8.1 SCSI MESSAGE DESCRIPTION 

The ACB-3 530A supports SCSI messages to allow 
disconnect/reconnect and provide communication between the host 
and controller. 

Table 5-3 shows the messages supported by the ACn-3530A. 

TABLE 5-3. SCSI MESSAGES SUPPORTED BY THE ACB-3530A 



CODE 

OOh 
02h 
03h 
04h 
05h 
06h 
07h 
08h 
OCh 
8 Oh 



- FFh 



DESCRIPTION 




DIRECTION 


Command Complete 




In 


Save Data Pointer 




In 


Restore Data Pointer 


In 


Disconnect 




In 


Initiator Detected 


Error 


Out 


Abort 




Out 


Message Reject 




In Out 


No Operation 




Out 


Bus Reset 




Out 


Identify 




In Out 



Command Complete (OOh): The Command Complete message is sent by 
the ACB-3530A to indicate that the last command has terminated. 
This message will always follow a valid status byte. Immediately 
after this message the bus will be placed in the Bus Free phase. 

Save Data Pointer (02h): The Save Data Pointer message is sent 
by the ACB-3530A to direct the host to save the active command 
execution state prior to disconnect. The host typically stores 
pointers to command, status, and data areas of memory related to 
the disconnecting command. 

Restore Data Pointers (03h): The Restore Data Pointers message 
is sent by the ACB-3530A to direct the host to restore themost 
recently saved pointers for logical unit indicated in the 
preceding Identify message to the active state. 

Disconnect (04h): The Disconnect message is sent by the ACB- 
3530A to inform the host that the present physical path is going 
to be broken by disconnection. This message is always preceded 
by a Save Data Pointers message. Immediately after this message, 
the bus will be placed in a Bus Free phase. 
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Initiator Detected Error (05h): The Initiator Detected Error 
message is sent by the initiator when it receives a parity error 
from the target, 

.Abort (06h) : The Abort message causes the ACB-3530A to reset. 

Message Reject {07h): The Message Reject message can be sent 
from either the initiator or target to inform the other that the 
last message sent was either inappropriate or not implemented. 

No Operation (08h): The No Operation message is used by the host 
to respond to the Measge Out phase when there is no valid message 
to send. 

Bus Reset (OCh): The Bus Reset message causes the ACB-3530A to 
reset. 

Identify (80h - PPh)s The Identify message is sent by either the 
host or controller to establish a physical path connection 
between the host and the ACB-3530A controller. The format of the 
Identify message is shown in Figure 5-7. 



BIT 



6 5 4 3 2 1 
.. I I -I .. I ---_ I -. I 

Discn Logical Unit No. 



FIGURE 5-7. IDENTIFY MESSAGE 

Disconnect (Bit 6): This bit is set in a host to controller 
message indicating the host's ability to disconnect. This 
message is sent after controller selection. 

Logiczil Unit Number (Bits 0, 1, and 2): The logical unit number 
is used to inform the host of which logical unit attached to the 
controller is reconnecting, or to inform the controller which 
logical unit is being selected (if system is disconnecting). 
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6.0 COMMAND DESCRIPTIONS 



This Section describes the command set implemented by the ACB- 
3530A. This command set follows the ANSI X3.331 ,- 1986, however, 
deviations do occur to support special Adaptec functions. Table 
6-1 summarizes the implemented command set. 



TABLE 6-1. 


ACB-3530A SCSI COMMAI'TD SET 


COMMAND OPCODE 


COMMAND 


SECTION 


OOh 


Test Unit Ready 


6.1 


Olh 


Rewind Tape (D) 


6.2 


03h 


Request Sense 


6.3 


05h 


Read Block Limits 


6.4 


06h 


Set Parameters 


6.5 


08h 


Read (D) 


6.6 


OAh 


Write (D) 


6.7 


lOh 


Write File Mark (D) 


6.8 


llh 


Space (D) 


6.9 


12h 


Inquiry 


6.10 


13h 


Verify (D) 


6.11 


14h 


Recover Buffer Data 


6.12 


15h 


Mode Select 


6.13 


16h 


Reserve Unit 


6.14 


17h 


Release Unit 


6.15 


19h 


Erase (D) 


6.16 


lAh 


Mode Sense 


6.17 


IBh 


Load/Unload Unit (D) 


6.18 



(D) = Disconnecting Commands 
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6.1 TEST UNIT READY COMMAND (OOh) 

This command returns the status of the attached tape drive. A 
good completion status, OOh status byte, indicates the drive is 
powered-on with cartridge inserted and ready for operation. 
Figure 6-^1 shows the Command Descriptor Block (CDB) for Test Unit 
Ready. 
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FIGURE 6-1. TEST UNIT READY COMMAND 

6.1.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following error 
codes could be returned from a Reguest Sense (03h) command: 

SENSE KEY ERROR POSSIBLE CAUSE 

2 Unit Not Ready See Section 6.3.3 

4 Hardware Error See Section 6.3.3 

6 Unit Attention See Section 6.3.3 
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This command rewinds the cartridge tape to the beginning of tap'. 
(nOT). Figure 6-2 shews the CDB for the Hevirrd cc~~5~c, 
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FIGURE 6-2. REWIND COMMAND 

If the host does not support disconnect and the Immediate bit 
(byte 01, bit 00) is notset, this command will return a 
completion status at the end of the rewind process. If the 
Immediate bit is set, the ACB-353QA will return goodcompletion 
status at the initiation of rewind. During the rewind, the 
controller will return a Busy status in response to all commands. 

If the host has indicated the ability to disconnect (through the 
Identify message), the ACB-3530A will disconnect, during the 
rewind process and reconnect to present ending status. 

6.2.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following error 
codes could be returned from a Reguest Sense (03h) command: 

SENSE KEY ERROR POSSIBLE CAUSE 

2 Unit Not Ready See Section 6.3.3 

4 Hardware Error See Section 6.3.3 

6 Unit Attention See Section 6.3,3 
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6.3 REQUEST SENSE COMMAND (03h) 

This command returns Unit Sense information for the specified 
logical unit. Unit sense can provide the host information 
regarding a Check status condition, tape access retries* buffer 
status and tape status. Sense information will be valid for the 
last Check status sent to the host. Sense data will be cleared 
upon receiving a subsequent command, from the host that received 
the Check status. Access attempts from other hosts will result 
in a Busy status until the Unit Sense information has been 
cleared. This command, therefore, should always follow a Check 
status. Figure 6-3 shows the CDB for the Request Sense command. 
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FIGURE 6-3. REQUEST SENSE COMMAND 

Number of Bytes (Byte 04): This byte specifies the number of 
bytes allocated by the host for returned Unit Sense information. 
A value of will default to four bytes; it is recommended that 
16 bytes be allocated for sense data. The controller will return 
the exact number of bytes specified. 

The sense information returned by this command is detailed in 
Section 6.3.2. 

6.3.1 POSSIBLE ERROR STATES 

This command could result in a Busy status, see Section 5.7 for a 
description of the possible cause. 

A Check status will not be returned in response to this command. 

6.3.2 UNIT SENSE INFORMATION 

Sense information returned as a result of the Request Sense 
command is in the SCSI extended sense format. The sense data 
will be valid for the Check status just presented to the host. 
Sense data will be cleared on any subsequent command from the 
host receiving a Check status. Figure 6-4 shows the format of 
the sense bytes returned by the ACB-3530A. 
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FIGURE 6-4. SENSE INFORMATION 

Address Valid (Bit 1, Byte 00): This bit set indicates that the 
information contained in the Block Count bytes (03 - 06) is 
valid. 

File Mark (Bit 1, Byte 02): This bit will be set to indicate 
that the last block processed was a file mark. Read, Verify, and 
certain Space commands will terminate on a file mark. 

End of Media (Bit 6, Byte 02): This bit will be set when the end 
of physical tape warning is encountered while accessing the last 
track of the tape. 

Sense Key (Bits 0~3, Byte 02): The sense key contains the error 
code (if any) that caused the last Check status. A detail of 
possible error codes is contained in Section 6.3.3. 
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Block Count (Bytes 03 -06): The block count contains the number 
of blocks not processed (written to tape) f rom a 1 1 buf f ered and 
current commands. The use of block count will vary with the 
initial command issued. Refer to the individual command detail 
to determine the meaning of this field. The Block Count is only 
valid if the Valid bit is set. 

The following information, contained in bytes 08 to OF, provides 
additional error, controller state, and drive state data. 

Cartridge Not Inserted, CNI (Bit 6, Byte 08): This bit set 
indicates the tape cartridge is not inserted. 

Write Protect, WRP (Bit 4, Byte 08): This bit set indicates the 
inserted drive is write protected, inhibiting tape writes. 

Snd of Media, EOM (Bit 3, Byte 08): This bit is set to indicate 
that end of physical tape warning has been encountered. This bit 
is identical to bit 6, byte 02. 

Unreadable Data Encountered, UDE (Bit 2, Byte 08): This bit set 
indicates that a block cannot be successfully read or written. 
The ACB-3530 will retry a read or write 16 times. 

Block Not Located, BNL (Bit 1, Byte 08): This bit set indicates 
that the block the controller is attempting to access, N, cannot 
be found. This will be reported when blocks N+1 and N+2 are 
found and not N after 16 attempts. This error may occur during 
any tape access and when locating the last block on the tape for 
appending data. 

File Mark Encountered, PIL (Bit 0, Byte 08): This bit set 
indicates that a file mark has been encountered. This bit is 
identical to bit 7, byte 02. 

No Data Detected, NDD (Bit 5, Byte 09): This bit is set to 
indicate that a span of erased tape has been encountered. 

Beginning of Media, BOM (Bit 3, Byte 09): This bit set indicates 
that the tape is positioned at the physical beginning of the 
media. 

Parity Error, PER (Bit 2, Byte 09): This bit set indicates a 
parity error has occured on a transfer to the controller. 

Power-On Reset, POR (Bit 0, Byte 09): This bit set indicates 
that a power-on or SCSI reset has occurred clearing all 
reservations and Commands in process. The sense key. Unit 
Attention (06) will always be reported with this bit. 
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Underrun Counter (Bytes OC-OD): The Underrun Counter contains 
the number of times a normal streaming operation was interrupted 
because of an underrun or overrun of data in the controller 
buffer. 

Current Track (Byte OE); The Current Track contains the track 
number, starting at 0, that the read and write heads are currently 
positioned over. 

Blocks To Go (Byte OF): The Blocks To Go contains the number of 
blocks that have been written into the buffer and not written to 
tape from previously completed and current write operations. This 
information can be used by the host to determine the status of a 
buffered write. 

6.3.3 SENSE KEYS 

The sense key returned in the Unit Sense Information, indicates 
the error state causing the last Check status. Generally, the 
sense key should always be checked after a Check status to 
determine the nature of the operational failure. 

The sense keys supported by the ACB-3530A are detailed in Table 
6-2. 

TABLE 6-2. ACB-3530A SENSE KEYS 

SENSE KEY ERROR 

No Sense 

1 Recovered Error 

2 Device Not Ready 

3 Media Error 

4 Hardware Error 

5 Illegal Request 

6 Unit Attention 

7 Data Protect 

8 Blank Check 

9 Not Used 
A Not Used 

B Aborted Command 

C Not Used 

D Volume Overflow 

E Not Used 

F Not Used 

No Sense (0): No Sense information available. The last command 
for this LUN was successful. File mark or EOM may have been 
encountered, the appropriate sense bits will be set. 

Recoverable Error (1): The last tape access was successful <i fter 
retries. 
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Not Ready (2): The addressed unit cannot be accessed. This can 
be caused by no cartridge inserted, no power applied to drive, or 
a faulty QIC-36 cable. 

Media Error (3): The last tape access was unsuccessful. This is 
likely due to a flaw in the media. 

Hardware Error (4): The ACB-3530A detected an uncorrectable 
hardware error. This is generally caused by the lack of capstan 
tach pulses from the drive or a faulty QIC-36 cable. 




data byte is transferred. If an illegal byte is contained in the 
command, a Check status will be reported after the entire GDB is 
transferred. 

Unit Attention (6): The tape cartridge has been changed (removed 
and reinserted) or a reset has occurred since the last command. 
This will be returned in response to the first command from each 
host after the condition is detected. These commands will result 
in a Check status and not be executed. If this sense key is a 
result of a device reset, power-on or SCI, the POR sense bit will 
be set. 

Data Protect (7); A write was attempted to a tape that is write 
protected. 

Blank Check (8): The end of recorded media was encountered 
during a read. The host has attempted to read beyond the last 
recorded block number. 

Aborted Command (B): The ACB-3530A abortedthe command. The 
command should be reissued by the host. 

Volume Overflow (D): A completed, buffered, write reached the 
physical EOM before all the data was written to tape. A Recover 
Buffer Data command (14h) maybe issued to recover the data in the 
buffer. 
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6,4 READ BLOCK LIMITS COMMAND (05h) 

The Read Block Limits command returns the minimum and maximum 
block size currently written on the tape. The ACB-3530A supports 
only 512-byte, QIC-24 and QIC-1 1, forma tted blocks. Both the 
minimum and maximum block size will equal 512 bytes. Figure 6-5 
shows the CDB for the Read Block Limits command. 
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FIGURE 6-5. READ BLOCK LIMITS COMMAND 

Figure 6-6 shows the data returned by the controller in response 
to this command. 
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FIGURE 6-6, READ BLOCK LIMITS DATA RETURNED 

6.4.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 
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If this command results in a Check status, the following error 
codes could be returned from a Request Sense (03h) command: 



SENSE KEY 



ERROR 



POSSIBLE CAUSE 



Unit Not Ready 
Hardware Error 
Unit Attention 



See Section 6.3.3 
See Section 6.3.3 
See SEction 6.3.3 



6. 5 SET PARAMETERS COMMAND (06h) 

The Set Parameters command allows the host to configure the 
controller to the attached drive and set specific parameters 
related to read and write operation. Some parameters specified by 
this command may also be established through the Mode Select 
command (15h). The controller will use the parameters contained 
in the last command issued (Set Parameters or Mode Select). 
Figure 6-7 shows the CDB for the Set Parameters command. 
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FIGURE 6-7. SET PARAMETERS COMMAND 

Drive Manufacturer (Bits 0-4, Byte 01): The characteristics of 
the capstan tachometer pulses from the tape drive can vary between 
drive manufacturers. The ACB-3530A can optimize up-to-speed 
performance when the drive manufacturer is specified. This field 
is set as follows: 
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Ntimber of Tracks (Byte 02): This byte specifies the maximum track 
number supported by the tape drive. The track count begins at 0, 
therefore, a nine-track tape would be indicated with an 8 in the 
byte. This parameter replaces the number of tracks specified by 
the Mode Select command. 

Minimum Block Transfer (Byte 03): This byte specifies the minimum 
number of 512-byte blocks to be transferred to-* the controller at 
any one time. This parameter replaces both read and write 
thresholds specified by the Mode Select command. 

In disconnecting systems, this value will determine when the ACB- 
3530 A disconnects and reconnects. The controller will disconnect 
after transferring the specified number of bytes and reconnect 
when space is available for this number of blocks. This value is 
ignored on the last transfer of a command if it is less than the 
specified minimum. 

Extended Mode (Bit 2, Byte 04): This bit set enables the ACB- 
3530A to perform extended write. In the extended mode the 
controller will continue streaming even if a buffer underrun 
occurs. The controller will continue to write the last block 
indefinitely until another block of data is available in the 
buffer, the end of the physical track is reached, or a new 
command is issued. This parameter sets the forced streaming value 
of the Mode Select command to FF. 

QIC Format (Bit 0, Byte 04): This bit specifies which QIC format 
the inserted cartridge utilizes. This bit set to 1 indicates a 
QIC-11 format, reset to indicates QIC-24. This parameter sets 
the Density Code of the Mode Select command to 04, for QIC-11, or 
05, for QIC-24. 

6.5.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following error 
codes could be returned from a Request Sense (03h) command: 

SENSE KEY ERROR POSSIBLE CAUSE 

2 Unit Not Ready See Section 6.3.3 

5 Illegal Request Minimum Block Transfer 

exceeds buffer size 
4 Hardware Error See Section 6.3.3 

6 Unit Attention See Section 6.3.3 
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6.6 READ COMMAND (08h) 

The Read command reads the specified blocks from the attached tape 
and transfers them to the requesting host. Figure 6-8 shows the 
CDB for the Read command. 
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FIGURE 6-8 



READ COMMAND 



The reading will begin from the current tape position if the 
previous command left the tape at position for the read. This can 
be accomplished by a previous Read, Verify or Space command. 
Otherwise, the read must begin at BOT, indicated by the BOM bit in 
Unit Sense information (Section 6.3.2). This can be accomplished 
by a Rewind command. An attempt to execute a Read command when 
the above conditions are not met wil 1 result in a Check status and 
an Illegal Request (05) sense key. The read operation will 
terminate when all requested blocks are transferred, media or 
hardware errors occur, or a file mark or recorded end of tape is 
encountered. 



The ACB-3530A will attempt to cache data on a 1 1 tape reads. A 
multiple block Read command will cause the controller to fill the 
8K buffer with the next sequential blocks in anticipation of 
another read. This can be used to facilitate overlapped disk 
restore operations in nondisconnecting systems by executing a 
number of tape reads. 

In a disconnecting system, the ACB-3530A will disconnect from the 
host when the buffer becomes empty, during the data transfer. 
The control ler twii 1 reconnect when the buffer has filled to a 
specified "threshold," This value is set by either the Set 
Parameters (06h) command. Minimum Number of Blocks byte, or the 
Mode Select (15h) command. Read Threshold byte. A value of in 
either of these bytes will default to eight blocks, 4K of data. 
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A buffer overrun will occur if the host fails to empty the buffer 
fast enough. In the event of an overrun, the ACB-3530A will 
resposition the tape and wait for the buffer to become empty to 
resume reading. This sequence can take up to two seconds and can 
seriously degrade system performance. The host can monitor the 
frequency of data overruns through the Request Sense (03h) 
command, Underrun Counter. 

The ACB-3530A will not transfer blocks containing errorsto the 
host. Unrecoverable read errors will be reported to the host with 
a Check status and a Media Error (03) sense key. The suggested 
recovery is to space, one block, over the defective block and 
continue reading. 

6.6.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 



SENSE KEY 



ERROR 



POSSIBLE CAUSE 



No Sense 
Unit Not Ready 
Media Error 
Hardware Error 
Illegal Request 



Unit Attention 
Blank Check 



See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
Check that bit 0, byte 
01 is set. 

Previous command was a 
write type command . 
See Section 6.3.3 
See Section 6.3.3 



The Data Error Counter will be incremented each time the tape must 
be repositioned to reread a bad block. 

The Data Underrun Counter will be incremented each time the tape 
must be stopped to allow the host to empty the buffer. 
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6.7 WRITE COMMAND ( OAh ) 

The Write command will, transfer the specified number of blocks 
from the host and sequentially write the m onto the attached tape. 
Figure 6-9 shows the CDB for the Write comrnand. 
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FIGURE 6-9. WRITE COWi^iAND 

The write operation is initiated with the controller transferring 
the first block of data into the buffer at which point the write 
begins. 

The writing will begin from the current tape position if the 
previous command left the tape at position for the write. This 
can be accomplished by a previous Write, Write File Mark, or 
Space (to end of recorded media) command. Otherwise, the write 
inust begin at BOT, indicated by the BOM bit in Unit Sense 
information (Section 6.3.2). This can be accomplished by a 
Rewind or Erase command. Any attempt to execute a Write command 
without the above conditions met will result in a Check status 
and an Illegal Request (05) sense key. The write operation will 
tierminate when all requested blocks are transferred, media or 
hardware errors occur, or physical end of tape (Section 6.7.2) is 
encountered. 

The ACB-3530A supports two modes of write operation; buffered and 
nonbuffered. The mode used is specified by the Mode Select (15h) 
command. The nonbuffered mode will not present a completion 
status until all the blocks have been written to tape and 
verified. The buffered mode will present a completion status as 
the last block to be written has been transferred into the 
controller buffer. 

The controller buffer is configured for 15 blocks of buffered 
write data . 
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The buffered mode is invoked through the Mode Select (15h) 
command. It has been implemented on the AGB-3530A to help 
facilitate streaming back-up in a nondisconnecting system. Once 
the host has filled the controller buffer and a completion status 
and message has been' issued, the host has approximately 60-70mS 
to reissue the next sequential write operation. This time allows 
the host to obtain additional disk data. The next write wi 1 1 
refill the buffer as space becomes available until the last block 
is transferred, when completion is again issued. If an error is 
encountered on writing buffered data for which a good completion 
status has already been issued, a Check status will be posted on 
the next tape access from the same host. See Section 6.7.3 for 
proper recovery. 

The nonbuffered mode is generally used with a disconnecting 
system. The ACB-3530A will disconnect from the host when the 
buffer becomes full. The controller will reconnect when the 
buffer is emptied to a specified "threshold." This value is set 
through the Set Parameters (06h) command. Minimum Number of Blocks 
byte or the Mode Select (15) command. Write Threshold byte. The 
parameters contained within the last of these two issued willbe 
used. A value of in either of these bytes will result in a 
default of eight blocks, 4K of data. The controller will report a 
completion status when the last block has been written to tape and 
verified. 

6.7.1 FORCED STREAMING 

The ACB-3530A will attempt to keep the tape streaming on all 
write operations if a buffer underrun occurs in the forced 
streaming mode, A buffer underrun occurs during a buffered or 
nonbuffered write operation when the host is not capable of 
transferring the blocks specified by the Write command into the 
controller buffer fast enough to supply the tape write. In the 
event of a buffer underrun, the ACB-3530A will continue to stream 
the tape by continuously rewriting the last block. This forced 
streaming will continue for a maximum of the number of blocks 
specified in the Mode Select, Forced Streaming byte or until the 
end of the track, if the Set Parameters, Extend bit is set. The 
parameters in the last of these two commands issued will be used. 
Once the next block is available in the buffer, the controller 
will resume the write operation. 

OIC-24 Operation 

Forty-five inches of blank tape will always be written when the 
controller drops out of streaming during a write command. This 
assures a legal QIC-24 tape in all circumstances. 
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QIC-11 Operation 

QIC-11 coinpatibiLity is supported on the ACB~3530A, Ail QIC-11 
command and format are supported. However, use of the backspace 
command (i.e., SPACE command, option 0, with a negative count) is 
NOT RECOMMENDED. The reason for this restriction is that the 
QIC-11 format only allows for a single-byte ID field. This 
precludes precise positioning of the tape when moving backwards 
since the same ID can occur multiple times on a single tape, and 
the tape is not read when moving backwards. Furthermore, the 
possibility of extended writes (multiple consecutive blocks with 
the same ID) prevents the use of some type of positioning by 
length of tape or time of tape motion. Since these backspace 
attempts are not reported as errors, serious data integrity 
problems can arise if this command is attempted. 

6.7.2 ENCOUNTERING END OF MEDIA 

The host will be informed of the end of media when the early 
warning is detected by the ACB-3530A. The current block written 




current and all previous commands, not written to tape. In the 
buffered mode, the Check status will be posted with the next 
access to the tape from the same host. Buffered data, completed 
but not yet written to tape, can be recovered as detailed in 
Section 6.7.3. 

The tape will typica 1 ly hold some additional number of blocks 
between earlywarning andthe physical end of tape. If 
necessary, additional blocks or file marks can be written, one at 
a time, until the end of tape is reached. Multiple block writes 
will result in a Check status with an Illegal Request sense key. 
Single block writes will terminate with a Check status with the 
EOM bit set and a No Sense (0), sense key. The number of 
additional blocks written should not exceed five. When a block 
write is interrupted by the physical EOM, a Check status will be 
posted with the EOM bit set and a Media Error (03) sense key. 
Since the interrupted block has not been verified it is not 
recoverable, 

6.7.3 WRITE ERRORS DURING BUFFERED MODE 

Recovering from errors encountered while writing data for which a 
good completioh status has already been issued can be 
problematic. The ACB-3530A provides the host the capability to 
effectively recover from these errors. Upon encountering an 
error state, the controller will post a Check status. If write 
data from a write operation is currently being written into the 
buffer, the transfer will be interrupted with a Check status. If 
no subsequent command has been issued, a Check status will be 
posted with the next command from the same host. The related 
sense key will indicate the cause of the error state. Any 



attempts from another host to access the controller when an 
outstanding Check status is present will result in a Busy status 
to that host. 

Assuming that a subsequent command has transferred data into the 
buffer and is interrupted by a Check status, the host can 
determine which blocks have been written to tape and recover the 
data in the buffer. 

To determine how many blocks have been written to the tape, the 
host should issue a Request Sense command to determine the Block 
Count. This value reports the number of blocks from the current 
and all previously buffered write commands that have not been 
written to tape. The Blocks to Go value (Byte OF) reflects the 
same information. 

When the host determines the residue block count of the previous 
buffered and current commands, a Recover Buffer Data (14h) 
command can be used to read the buffer data back into the host. 
This command will return all bytes left in the buffer from the 
current and all previous commands. The number of blocks 
specified in the command should equal the number of blocks in the 
buffer to ensure all buffered data will be recovered, however, 
more than one command can be used to recover all of the data. If 
thenumber of blocks transferred is less than the number 
specified, the ACB-3530 will present a Check status with the EOM 
bit set and a No Sense (0) sense key when the last block 
available in the buffer has been transferred. The Block Count in 
the Unit Sense information contains the difference between the 
number of blocks specified and number recovered. See description 
of Recover Buffer Data command, Section 6.12, for further 
details. 

Once the data has been recovered, a Write File Mark (lOh) command 
is required to flush the buffer and resume normal write 
operations. 

6.7.4 MEDIA DEFECT HANDLING 

The ACB~3530A checks each block on the tape for good CRC as it is 
being written. However, since the tape read head trails the 
write head by about 300 bytes, the CRC results for a given block 
(block N) are not known until after the next block write (N+l) 
has begun. The controller, therefore, assumes that the previous 
block will check correctly and begins writing the next block. A 
block will not be considered transferred to tape until a 
successful CRC check is completed. 

If the CRC check should fail, typically due to a media defect, 
the ACB-3530A will complete the current block write ( N+1 ) and 
then rewrite the previous block (N). This alternation between N 
and N+1 will continue until a successful CRC check of block N is 
achieved or 16 unsuccessful writes have been attempted. If block 
N were the last block to be written, it wou Id be repeated until a 
good CRC check is made. This results in the last block of each 
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write to be written at least twice. After 16 unsuccessful 
attempts, a Check status will be posted with a Media Error (03) 
sense key. 

6.7.5 POSSIBLE ERROR STATES 



This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense {03h) command: 



SENSE KEY 



ERROR 



POSSIBLE CAUSE 



No Sense 

Unit Not Ready 
Media Error 
Hardware Error 
Illegal Request 



Unit Attention 
Data Protect 

Volume Overflow 



See Section 6.3.3 

Writing at EOM 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 

Check that bit 0, 

byte 01 is set. 

Previous command 

was a read type 

comma nd . 

See Section 6.3.3 

See Section 6.3.3 

Cartridge write protect 

See Section 6.3.3 

Writing at EOM. 



The Data Error Counter will be incremented for each block that 
must be rewritten due to a CRC error. 

The Data Underrun Counter will be incremented each time the tape 
must be stopped to allow the host to fill the buffer. 
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6.8 WRITE FILE MARK COMMAND (lOh) 

The Write File Mark command writes the specified number of file 
mark blocks to the tape, starting from the current tape position. 
File marks are used by the host for file management by 
partitioning areas of the tape with one or more sequential file 
marks. Figure 6-10 shows the CDB for the Write File Mark 
command. 
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FIGURE 6-10* WRITE FILE MARK COMflAND 

The number of sequential file marks specified by the File Mark 
Count will be written to the tape. The file mark write will 
begin at the current tape position if the previous command left 
the tape at position for the write. This can be accomplished by 
a previous Write, Write File Mark, or Space (to end of recorded 
media). Otherwise, the file mark write must begin at BOT, 
indicated by the BOM bit in Unit Sense information (Section 
6.3.2). This can be accomplished by a Rewind or Erase command. 
Any attempt to execute a Write File Mark command without the 
above conditions met will result in a Check status and an Illegal 
Request (5) sense key. The write operation will terminate when 
all requested file mark blocks are transferred, media or hardware 
errors occur or physica 1 end of tape (Section 6.6.2) is 
encountered. 

A File Mark Count of will result in no file marks to be 
written, however, the command will not be completed until all 
buffered data from a previous Write command is transferred to 
tape. This may be used to ensure that the last buffered write 
transfers successfully to tape. 

In a disconnecting system, the ACB-3530A will disconnect on file 
mark writes. The controller will reconnect to present command 
completion. 
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6 « 8 . 1 POSSIBLE ERROR STATES 

This comrnand could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 



SENSE KEY 



ERROR 



POSSIBLE CAUSE 



D 



No Sense 

Unit Not Ready 
Media Error 
Illegal Request 



Hardware Error 
Unit Attention 
Data Protect 



Volume Overflow 



See Section 6.3.3 
Writing at EOM 
See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
Previous command was 
a read type command. 
See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
Cartridge Write 
Protected. 
See Section 6.3.3 
Writing at EOM. 



The Data Error Counter will be incremented for each file mark 
that must be rewritten due to a CRC error. 



The Data Underrun Counter will be incremented once when 
repositions after the last file mark is written. 



tape 
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6.9 SPACE COMMAND (llh) 

The Space command is used to change the physical location of the 
tape in either the forward or reverse direction. This command is 
the only command that can be used to place the tape at position 
for both a read and write operation. Figure 6-11 shows the CDB 
for the Space command. 
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FIGURE 6-11 



SPACE COMMAND 



The type of tape positioning is specified by the Search Code. 
The direction and amount of tape motion is specified by the Space 
Count value, N. A positive N will result in a forward motion, a 
negative N will result in a reverse motion. Negative N values 
are represented in two's complement notation. A zero value will 
result in no tape motion. 

The Space command allows the host to space across blocks, file 
marks, or to the end of recorded media depending on the Search 
Code. The definition of each Search Code, through 3, is shown 
in Table 6-3. 

TABLE 6-3. SPACE SEARCH CODES 



SEARCH CODE 



SPACE FUNCTION 



Space Blocks 

Space File Marks 

Space Sequential File Marks 

Space to End of Recorded 

Media 



Search Code =0: Space blocks. Space over N blocks, either 
forward or reverse, depending on the sign of N. The space will 
terminate when the specified number of blocks have been passed, 
with a good completion. If EOT, BOT, a file mark, or end of 
recorded media is encountered, a Check status will be posted with 
the appropriate sense bits set. 
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A forward space will complete with the tape positioned at the end 
of the last block spaced or a file mark encountered. 

A reverse space will complete with the tape positioned at the 
beginning of the last block spaced. The ACB^3530A does not 
search for file marks on a reverse space, any encountered will be 
treated as data blocks. Reverse spaces are limited to 128 blocks 
(Space Code = FFFFSOh). 

Search Code =* 1: Space File Marks. Space over N file marks in 
forward direction, toward EOT (a space in the reverse direction 
will result in tape motion to BOT, no file marks will be found). 
The space will terminate when the specified number of file marks 
has been spaced with a good completion. If EOT,BOT, or end of 
recorded media is encountered, a Check status will be posted with 
the sppropriate sense bits set. 

The space will complete with the tape positioned at the end of 
the last file mark spaced. 

Search Code =2: Space Sequential File Marks. Spaces the tape 
forward until the next occurrence of N sequential file marks. 
Only positive counts are supported. The space will terminate 
when the specified number of sequential file marks has been 
encountered with a good completion. If EOT or end of recorded 
media is encountered, a Check status will be posted with the 
appropriate sense bits set. 

The space will complete with the tape positioned at the end of 
the last of the sequential file marks encountered. 

Search Code =3: Space to End of Recorded Media. Spaces the 

tape to the end of the recorded media. The tape is left in the 

position to append data to the last block written. The Space 
Count field is ignored. 

A multiple block space operation will reread blocks with CRC 
errors until a good read is accomplished. Single block spaces 
will bypass CRC errors after 16 retries. This allows the host to 
space past bad blocks on prewritten tapes. 

On systems that support disconnection, the ACB-3530A will 
disconnect during lengthy tape motion and reconnect to present 
completion status. 

6.9.1 POSSIBLE ERROR STATES 

This command could return a busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 
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SENSE KEY 



ERROR 



POSSIBLE CAUSE 





2 

3 
4 
5 
6 
D 



No Sense 

Unit Not Ready 
Media Error 
Hardware Error 
Illegal Request 
Unit Attention 
Volume Overflow 



See Section 6.3.3 

EOM encountered 

See Section 6.3,3 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 

See Section 6.3.3 

Spa cinq past BOT or EOT 



The Data Error Counter will be incremented each time the tape 
must be repositioned to reread a bad block. 

The Data Underrun Counter will be incremented once when tape 
repositions after the last space. 

6.10 INQUIRY COMMAND (12h) 

The Inquiry command passes information regarding the controller 
and attached device type to support self-configuring systems. 
The CDB for the Inquiry command is shown in Figure 6-12. 
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FIGURE 6-12 



INQUIRY COMMAND 



The number of bytes allocated by the host to be returned as 
Inquiry data is specified in block 04. A value of zero will 
result in no data transferred. The total number of bytes 
available is 18, (decimal). Figure 6-13 shows the returned 
Inquiry data. 
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The Inquiry data indicates: 



Device Type Code =01 
Device Type Qualifier = 80 
ACB-3530A Firmware Rev. 
Number of Buffered Read Blocks 
Number of Buffered Write Blocks 
Adaptec Identifier 
Product Identifier 



Sequential Access 

Removable 

Firmware Rev. in X.Y 

16 (decimal) 

15 (decimal) 

A-D-A-P-T-E-C in ASCII 

Olh indicates ACB-3530A 
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Device Type Qualifier (80) 
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Number of Additional Bytes (ODh) 
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ACB-3530A Firmware Revision Level Byte 


(ASCII) 
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ACB- 


-3530A Firmware Revision Level Byte 


1 (ASCII) 


08 






Number of Buffered Read Blocks (lOh) 




09 






Number of Buffered Write Blocks i 


(OFh) 




OA 

• • 

10 






Adaptec Inc. Identifier 






11 






Product Identifier (Olh) 







FIGURE 6-13. INQUIRY DATA 






This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 



SENSE KEY 



ERROR 



POSSIBLE CAUSE 



Hardware Error 
Unit Attention 



See Section 6.3.3 
See Section 6.3.3 
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6.11 VERIFY COMMAND {13h) 

The Verify command performs a CRC check on the number of blocks 
specified. The controller only performs a CRC check, no data is 
transferred to the host. Figure 6-14 shows the CDB for the 
Verify command. 
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FIGURE 6-14. VERIFY COMMAND 

The verify will begin from the current tape position if the 
previous command left the tape at position. This can be 
accomplished by a previous Read, Verify , or Space command. 
Otherwise, the verify MUST begin at BOT, indicated by the BOM bit 
in Unit Sense information (Section 6.3.2). This can be 
accomplished by a Rewind command. An attempt to execute a Verify 
command when the above conditions are not met will result in a 
Check status and an Illegal Request (05) sense key. The 
operation will terminate when all requested blocks are 
transferred, media of hardware errors occur or a file mark, 
recorded end of tape, or physical end of tape is encountered. 

The command will verify the CRC on one or more blocks on the tape 
starting next block from the current position. The verification 
will terminate when the specified number of blocks have been 
verified, a file mark is encountered, or EOT is encountered. If 
termination occurs before the block count is reached, the Unit 
Sense information will contain the remaininq number of blocks. 

The controller will place the tape at the end of the last block 
verified or file mark encountered prior to completion. 

6.11.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 
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If this command results in a Check status, the followinq sense 
keys could be returned from a Request Sense (03h) command: 



SENSE KEY 



ERROR 



POSSIBLE CAUSE 



No Sense 
Unit Not Ready 
Media Error 
Hardware Error 
Illegal Request 



6 
7 
D 



Unit Attention 
Data Protect 
Volume Overflow 



See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
Check that bit 0, 
byte 01 is set. 
Previous command was 
a write type command 
See Section 6.3.3 
See Section 6.3.3 
See Section 6.3.3 
Verifying at EOM. 



The Data Error Counter will be incremented each time the tape 
must be repositioned to reread a bad block. 



The Data Underrun Counter will be 
repositions after the last space. 



incremented once when tape 



6.12 RECOVER BUFFER DATA COMMAND (14h) 

The Recover Buffer Data command is used to recover data left in 
the buffer as a result of an error occuring during a write 
operation. This command will return all buffer data from 
previously completed and current commands not yet written to tape 
and verified. Figure 6-15 shows the CDB for the Recover Buffer 
Data command. 
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FIGURE 6-15. RECOVER BUFFER DATA COMMAWD 

The data will be transferred in the order that it would have been 
written to tape. 
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The Block Count can be set to the maximum buffer size to ensure 
all buffered data is recovered* If a smaller count is used, 
multiple Recover Buffer Data commands can be used. If the Block 
Count exceeds the number of blocks available, a Check Status will 
be posted with a No Sense (0) sense key. The EOM bit will be set 
and the Unit Sense information Block Count will contain the 
di fference bet ween the number of blocks specified and 
transferred. 

6.12.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command. 



SENSE KEY 



ERROR 



POSSIBLE CAUSE 



No Sense 



Unit Not Ready 
Illegal Request 



Unit Attention 



See Section 6.3.3 

Block Count exceeded data 

available (EOM bit set) 

See Section 6.3.3 

See Section 6.3.3 

Check that bit 0, byte 01 

is set. 

See Section 6.3.3 

Spacing past ROT or EOT. 



6 . 13 MODE SELECT COMMAND (15h) 

The Mode Select command is used by the host to configure the ACB- 
3530 for the desired operational parameters. Some parameters can 
also be specified by the Set Parameters (06h) command. The 
overlapping values will be used from the last command issued. 
Figure 6-16 shows the CDB for the Mode Select command. 
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FIGURE 6-16. MODE SELECT COMMAND 
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The Number of Bytes specifies the number of bytes of 
configuration data to be sent to the controller, A minimum of 
three bytes must be sent for any meaningful data, however, less 
than three is not an error state. It is recommended that the 
host provide 17 bytes of data for full configuration. Figure 6-17 
shows the Mode Select configuration data block. 

The Mode Select configuration data is defined as follows: 

Buffered Mode (bit 4, byte 02): This bit set invokes the 
buffered mode of write operation. Good completion status and 
message will be transferred by the controller when the last byte 
of write data is transferred into the controller buffer. An 
error encountered will be posted with the next command. (See 
Section 6.7, Write command, for additional details) . 

Density Code (byte 04): This byte specifies the QIC format of 
theinserted tape. This can be overridden by the Set Parameters 
command. The density codes supported are: 

DENSITY CODE QIC FORMAT 

00 QIC-24 (default) 

04 QIC-11 

05 QIC-24 

Block Size (byte OA-OB): These bytes specify the formatted block 
size on the tape. This must be set to 512 (02,00h). 
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OC Operational Code (04h) 

OD Number of Tracks 



OE Read Threshold 

OF Write Threshold 



10 Forced Streaming Count 



FIGURE 6-17. MODE SELECT CONFIGURATION DATA BLOCK 
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The following fields define the operational mode of the ACB-3530A: 

Number of Tracks (Byte OD): This byte configures the controller 
to the number of tracks on the inserted tape. Track counts 
supported are 01 to 16, a value of 00 in this byte will default 
the controller to nine tracks. This can be overridden by the Set 
Parameters command Number of tracks value. 

Read Threshold (Byte OE): This byte sets the buffer threshold 
for when the controller will reconnect on disconnecting read 
operations. The threshold value specifies the number of blocks 
that must be available to transfer to the host before 
reconnection. A read operation can buffer up to 16 blocks. A 
zero in this field will default to 8. A value greater than 16 
will default to 15. This can be overridden by the Set Parameters 
command Minimum Number of Blocks value. 

Write Threshold (Byte OF): This byte sets the buffer threshold 
for when the controller will reconnect on disconnecting write 
operations. The threshold value specifies the number of blocks 
that must be free in the buffer before the controller will 
reconnect and request write data. A write operation can buffer 
up to 15 blocks. A zero in this field will default to eight 
blocks. A value greater than 15 will default to 14. This can be 
overridden by the Set Parameters command Minimum Number of Blocks 
value. 

Forced Streaming Count (Byte 10): This byte specifies the number 
of times the controller will rewrite the last block during a 
write operation in the event of a buffer underrun. A zero in 
this field will default to one block. A value of FF will result 
in a forced stream to the end of a track. An overriding Set 
Parameters command with the Extend bit set will set this field to 
FF. 

6.13.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 

SENSE KEY ERROR POSSIBLE CAUSE 

2 Unit Not Ready See Section 6.3.3 

6 Unit Attention See Section 6.3.3 
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6.14 RESERVE UNIT COMMAND (16h) 

The Reserve Unit command will reserve the attached tape drive for 
the exclusive use of the requesting host. The reservation is 
released by a Release command (ITh), a power-on or SCSI reset, an 
Abort message, or Bus Reset message. 

Figure 6-18 shows the CDB for the Reserve command. 
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FIGURE 6-18. RESERVE UNIT COMMAND 

An attempted access to a drive with an active reservation from 
another host will result in a Reservation Conflict status. 

6.14. 1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 



SENSE KEY 



ERROR 



POSSIBLE CAUSE 



Unit Not Ready 
Unit Attention 



See Section 6.3.3 
See Section 6.3.3 
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6.15 RELEASE UNIT COMMAND (17h) 

The Release Unit command releases a drive reservation invoked by 
the same host. Figure 6-19 shows the CDB for the Release Unit 
command. 
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FIGURE 6-19. RELEASE UWIT COMHAND 

A Release Unit command to a drive that has an active reservation 
from another host will result in a Reservation Conflict status, 

6.15.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 

SENSE KEY ERROR POSSIBLE CAUSE 

2 Unit Not Ready See Section 6.3.3 

6 Unit Attention See Section 6.3.3 
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6,16 ERASE COMMAND {19b) 

The Erase command will erase the entire tape inserted. The drive 
erase head covers the entire tape, all tracks will be erased in 
one forward motion from the beginning of track to the physical 
end of track 0, Figure 6-20 shows the CDB for the Erase command. 



BIT 



7 6 


5 


4 


3 


2 


-' 1 











1 


1 





1 




1 


Logical Unit 


No. 














1 























































































BYTE 
00 
01 
02 
03 
04 
05 



FIGURE 6-20. ERASE COMMAND 

The erase operation must begin at BOT. An attempt to erase a 
tape not at BOT will result in a Check status with an Invalid 
Request sense key. 

If the host has indicated the ability to disconnect (through the 
Identify message), the ACB-3530 will disconnect during the erase 
process and reconnect to present ending status. 

6.16.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 

SENSE KEY ERROR POSSIBLE CAUSE 

2 Unit Not Ready See Section 6.3,3 

4 Hardware Error See Section 6.3.3 

5 Illegal Request See Section 6.3.3 

Check that bit 0, byte 
01 is set. Tape not at 
BOT. 

6 Unit Attention See Section 6.3.3 

7 Data Protect See Section 6.3.3 
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6, 17 MODE SENSE COMMAND (lAh) 

The Mode Sense command will return the configuration parameters 
set by the Mode Select or Set Parameters command to the host. 
Figure 6-19 shows the CDB for the Mode Sense command. 
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FIGURE 6-21. MODE SENSE COMMAND 

The number of bytes specifies how many bytes will be returned by 
the controller. The format data returned is the same as the Mode 
Select Configuration Data (see Section 6. 13, Mode Select 
command). The entire configuration data length is 17 blocks. If 
a Set Parameters command has been issued last, the overlappirt-g 
parameters will reflect the Set Parameters values in the Mode 
Select value convention. 

6.17.1 POSSIBLE ERROR STATES 

This command could return a Busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the fol lowing sense 
keys could be returned from a Request Sense (03h) command: 

SENSE KEY ERROR POSSIBLE CAUSE 

2 Unit Not Ready See Section 6.3.3 

4 Hardware Error "See Section 6.3.3 

6 Unit Attention See Section 6.3.3 
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6.18 load/unload UNIT COMMAND (iBh) 

The Load/Unload command is used by the host to prepare the tape 
for insertion or removal. This command allows the host to place 
the tape at BOT or EOT and to retension the tape. Figure 6-20 
shows the CDS for the Load/Unload command. 
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FIGURE 6-22. LOAD/UNLOAD COMMAND 

The specific function of the Load/Unload command is determined by 
the Retension, Load, and EOT bits. The definition of each 
function is as follows: 

Retension (Bit 1, Byte 04): This bit set will cause the 
controller to retension the tape prior to any load or unload 
function. A tape retension consists of a rewind to BOT, motion 
to EOT, and a rewind back to BOT. This is recommended prior to 
writing to a new or stored tape. 

Load « 1 (Bit 0, Byte 04): This bit set indicates a load 
function. To properly initialize to inserted drives (without 
power-on reset), this function will cause the controller to 
position the tape at BOT and determine tape lenqth for proper 
write current. 

Load = (Bit 0, Byte 04): This bit and Retension bit cleared 
indicates an unload function. This function will cause the 
controller to position the tape at BOT or EOT (see EOT bit 
below) . 

EOT - I (Bit 7, Byte 05): This bit in an unload operation will 
result in the tape being positioned at EOT. This bit cleared 
will position the tape at BOT. 
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If the host does not support disconnect and the Immediate bit 
(byte 01, Bit 00) is not set, this command will return a 
completion status at the end of the load/unload process. If the 
Immediate bit is set, the ACB-3530A will return good completion 
status at the initiation of load/unload. Durinq the operation, 
the controller will return a Busy status in response all 
commands. 

If the host has indicated the ability to disconnect (through the 
Identify message), the ACB-3530A will disconnect during tape 
motion and reconnect to present ending status. 

6.18.1 POSSIBLE ERROR STATES 

This command could return a busy or Reservation Conflict status, 
see Section 5.7 for a description of possible causes. 

If this command results in a Check status, the following sense 
keys could be returned from a Request Sense (03h) command: 

SENSE KEY ERROR POSSIBLE CAUSE 

2 Unit Not Ready See Section 6.3.3 

4 Hardware Error See Section 6.3.3 

6 Unit Attention See Section 6.3.3 
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